MULTIPROCESSOR SYSTEM, SHARED-MEMORY CONTROLLING METHOD, 
RECORDING MEDIUM AND DATA SIGNAL EMBEDDED IN A CARRIER WAVE 
BACKGROUND OF THE INVENTION 
Field of the Invention 

5 The present invention relates to a multiprocessor system, including a plurality of 
processors, and, more particularly, to a multiprocessor system, a shared-memory 
controlling method, a recording medium and a data signal embedded in a carrier wave, for 
efficiently controlling access to a shared memory by each of the plurality of processors. 
Description of the Related Art 

10 Conventionally, there are proposed various methods for controlling access to a 

shared memory in a multiprocessor. Tor example, Unexamined Japanese Patent 
Application KOKAI Publication No. H4-291085 discloses a memory accessing technique 
to be employed multiprocessor systems. 

According to the technique disclosed in Unexamined Japanese Patent Application 

15 KOKAI Publication No. H4-291085, a 2-port memory serving as a shared memory and an 
access-flag area setting the access rights to the shared memory are set on each CPU 
included in the multiprocessor system, hi the multiprocessor system, only one CPU 
having successfully set an access flag in the access flag area is permitted to access the 2- 
port memory, so as to reliably realize the access to the shared memory - 

20 Additionally, Unexamined Japanese Patent Application KOKAI Publication No. 
H3 -054660 discloses a technique regarding a shared-memory management technique to 
be employed in multiprocessor systems. 

In the system disclosed in Unexamined Japanese Patent Application KOKAI 
Publication No. H3-054660, there are included a priority control circuit which has 

25 exclusive control over CPUs and a bus-gate circuit which controls the access to the shared 
memory by the CPUs. Any of those CPUs which intends to access the shared memory 
sends a request signal to the priority control, circuit. Upon this, the priority control 
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circuit exercises the exclusive control over the CPUs in accordance with the request 
signal sent from each of the CPUs, and sends a response signal to either one of the CPUs. 
After this, the priority control circuit controls a bus gale circuit, and sets the CPU to 
which the response signal is sent and the shared memory into a state where they cart be 
5 accessed. 

Hence, the multiprocessor system can access the shared memory while preventing to 
lower the system performance of the multiprocessor system. 

The multiprocessor system of this invention, however, has the following problems. 

In the conventional multiprocessor system, a recovery process for recovering the 
10 failure in updating data in the shared memory and a confirmation process for confirming 
whether data is updated in the shared memory can not be carried out in cooperation with 
each of processors. 

A non-volatile memory, such as a Rash Memory, etc. is employed as the shared 

memory of the multiprocessor system. Since the flash memory is expensive to buy, 
1 5 many Hash memories can nor be prepared. In this structure, it is preferred that the data 

handled by each of the processors be efficiently and centrally managed in the 

multiprocessor system. 

For example, in a multiprocessor system which handles a large volume of service 

data (e.g. data representing voices, picture images, motion images, etc.) which can be 
20 downloaded from an external host computer, it is desired that each of processors 

efficiently stores and updates the service data in the shared memory in cooperation with 

each other. 

In addition, in the conventional multiprocessor system, the processors can 
individually be reset. 
25 SUMMARY OF THE INVENTION 

The present invention has been made in consideration of the above. It is 
accordingly an object of the present invention to provide a multiprocessor system, a 
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shared-memory controlling method, a recording medium and a computer data signal, 
which overcome the problems of the conventional multiprocessor system, and for sending 
predetermined information between a plurality of processors, so as to execute a recovery 
process for recovering the failure in updating data in a shared memory and a confirmation 
5 process for confirming whether data is updated in the shared memory in cooperation with 
each other. 

Another object thereof is to provide a multiprocessor system, a shared-memory 
controlling method, a recording medium and a computer data signal, which overcome the 
problems of the conventional multiprocessor system wherein a plurality of processors can 
10 individually be reset. 

Jn order to achieve the above objects, according to the first aspect of the present 
invention, there is provided a multiprocessor system comprising: 

a plurality of processors which send and receive po^termined information to and 
from each other; and 

15 a shared memory which is shared and accessed by the plurality of processors one 
after another, and 

wherein each of the plurality of processors requests at least one of other processors 
included in the plurality of processors to access the shared memory that is to be done by 
the at least one of other processor?, in a case where each of the plurality of processors has 

20 accessed the shared memory. 

According to this invention, in a case where each of the plurality of processors 
accesses the shared memory and has updated predetermined data, each of the plurality of 
processors requests the at least one of other processors to access the shared memory. 
Upon this, the at least one of other processors re-read the same data as the predetermined 

25 data from the shared memory or update the predetermined data in the shared memory. 
As a result, predetermined information is transmitted between the plurality of processors, 
and a recovery process for recovering the failure in updating data in the shared memory 
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and a confirmation process for confirming whether data is updated in the shared memory 
can be performed in cooperation with each other. 
Each of the plurality of processors may 

request, in a case where each of the plurality of processors has normally updated 
5 predetermined data in the shared memory, the at least one of other processors to read 
same data as the predetermined data from the shared memory. 
Each of the plurality of processors may 

request, in a. case where each of the plurality of processors has not normally updated 
predetermined daia in the shared memory, the at least one of other processors to update 
1 0 the predetemiined data in the shared memory. 

In order to achieve the above objects, according to the second aspect of the present 
invention, there is provided a multiprocessor system comprising: 

a plurality of processors which send and receive predetermined information to and 
from each other; 

15 a shared memory which is shared and accessed by each of the plurality of 
processors; and 

an access manager which manages access to the shared memory by each of the 
plurality of processors, and 

wherein the access manager selects, in a case where the plurality of processors are in 
20 contention to access the shared memory, one of the plurality of processors being in 
contention and permits the selected processor to access the shared memory, and 

each of the plurality of processors requests at least one of other processors included 
in the plurality of processors to access the shared memory that is Co be done by the at least 
one of other processors, in a case where each of the processors is selected by the access 
25 manager and the selected processor accesses the shared memory. 

According to this invention, in a case where the plurality of processors are in 
contention for the shared memory, the access manger selects one of the plurality of 
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processors and permits the selected processor to access the shared memory. In the case 
where each of the processors is selected by the access manager and has updated 
predetermined data in the shared memory, each of the plurality of processors requests at 
least one of other processors to access the shared memory. Upon this, the at least one of 
5 other processors rc-rcad the same data as the predetermined data from the shared memory, 
or carry out an updating process for updating the predetermined data in the shared 
memory. As a result of this, predetermined information is transmitted between the 
plurality of processors, and a recovery process for recovering the failure in updating the 
data in the shared memory and a confirmation process for conjSrroing whether data is 
1 0 updated in the shared memory can be done in cooperation with each of the plurality of 
processors. 

Each of the plurality of processors may 

request, in a case where each of the plurality of processors has normally updated 
predetennined data in the shared memory, the at least one of other processors to read 
15 same data as the predetermined data from the shared memory. 
Each of the plurality of processors may 

request, in a case where each of the plurality of processors has not normally updated 
predetermined data in the shared memory, the at least one of other processors to update 
the predetermined data in the shared memory. 
20 Each of the plurality of processors may 

request, in a case where a predetermined period of time, has elapsed without being 
selected by the access manager, the at least one of other processors and the access 
manager to perfonn a predetermined reset operation for resetting themselves. 

In order to achieve the above objects, according to the third aspect of the present 
25 invention, there is provided a multiprocessor system comprising: 

a plurality of processors which send and receive a predetermined signal to and from 
each other; 
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a shared memory which is shared and accessed by each of the plurality of 
processors; and 

a contention determiner which delects whether the plurality of processors are in 
contention to access the shared memory, and permits one of the plurality of processor to 
5 access the shared memory, and 

wherein each of the plurality of processors outputs a access-request signal to at least 
one of other processors included in ihe plurality of processors, so as to request the at least 
one of other processors to access the shared memory, in a case where each of the plurality 
of processors is permitted to access the shared memory by the contention determiner and 
1 0 the permitted processor accesses the shared, memory. 

According to this invention, in a case where each of the processors is permitted to 
access the shared memory and update predetenriincd data in the shared memory, each of 
the processors requests at least one of other processors included, in the plurality of 
processors to access the shared memory that should be done by the at least one of other 
1 5 processors. Upon this, the at least one of other processors re-reads the same data as the 
predetermined data from the shared memory, or executes an updating process for 
updating the predetermined data in the shared memory. As a result of this, 
predetermined information can be transmitted between each of the plurality of processors, 
and a recovery process for recovering the failure in updating the prcdetejmined data in the 
20 shared memory and a confirmation process for confirming whether the data is updated in 
ihe shared memory can successfully be performed in cooperation with each of the 
plurality of processors. 

Each of the processors may 

output, in a case where each of the processors accesses the shared memory and has 
25 normally updated, predetermined data therein, a re-read request signal to the at least one of 
other processors, so as to request the at least one of other processors to read same data as 
the predetermined data from the shared memory. 
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Bach of the plurality of processors may 

output, in a case where each of the plurality of processors accesses the shared 
memory and has not normally updated predetermined data therein, an update-request 
signal to the at least one of other processors, so as to request the at least one of other 
5 processors to update the predetermined data in the shared memory. 

Each of the plurality of processors may output a reset-request signal to the at least 
one of other processors and the contention determiner, so as to request the at least one of 
other processors and the contention deteiminer to reset themselves, in a case where a 
predetermined period of time has elapsed without being selected by the access manager. 
1 0 In this case, each of the plurality of processors can individually be reset. 

in order to achieve the above objects, according to the fourth aspect of the present 
invention, there is provided a shared-memory controlling method to be executed in a 
multiprocessor system including a plurality of processors which send and receive 
predetermined information to and from each other, a shared memory which is shared and 
15 accessed by each of the plurality of processors, and an access manger which manages 
access to the shared memory by each of the plurality of processors, and the method 
comprising: 

selecting one processor included in the plurality of processors, and permitting the 
selected one processor to access the shared memory, in a case where the plurality of 
20 processors are in contention for the shared memory; 

performing first access to the shared memory using the selected processor; 
requesting at least one of other processors included in the plurality of processors to 
perform second access to the shared memory, in a case where the performing the first 
access to the shared memory has been done; and 
25 performing the second access to the snared memory using the at least one of other 
processors. 

According to this invention, the selecting includes selecting one processor and 
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permits the selected processor to access the shared memory, in a case where the plurality 
of processors are in contention for the shared memory. The performing the first access 
includes performing access to the shared memory using the processor selected at the 
selecting. The requesting includes requesting the at least one of other processors to 

5 access the shared memory, in a case where the first access (e.g. including the updating of 
predetermined information) to the shared memory has been done. The performing the 
second access includes performing access (including re-reading of same data as the 
predetermined data from the shared memory and updating the predetermined data in the 
shared memory, etc.) to the shared memory using the at least one of other processors. 

10 As a result of this, predeteraiined information can be transmitted between each of the 
plurality of processors, and a recovery process for recovering the failure in updating the 
predetenriined data in the shared memory and a confirmation process for confirming 
whether data is updated therein can successfully be performed in cooperation with each of 
the processors. 

15 The requesting may include requesting, in a case where predetermined data has 
normally been updated in the performing the first access, the at least one of other 
processors to read the predetermined data from the shared memory. 

The requesting may include requesting, in a case where predetermined data has not 
normally been updated in the performing the first access, the at least one of other 

20 processors to update the predetermined data in the shared memory. 

The requesting may include requesting, in a case where a predetermined period of 
time has elapsed without being selected in the selecting, the at least one of other 
processors and the access manager to perform a pi^eterroined reset operation for 
resetting themselves. In this case, each of the plurality of processors can individually be 

25 reset. 

In order to achieve the above objects, according to the fifth aspect of the present 
invention, there is provided a shared-memory controlling method comprising: 
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selecting one of a plurality of processors, and permitting the selected processor to 
access a shared memory shared by the plurality of processors, in a case where the 
plurality of processors are in contention for the shared memory; 

performing firs access to the shared memory using the selected processor; 
5 requesting at least one of other processors included in the plurality of processors to 
perform second access to the shared memory, in a case where the first access has been 
done; and 

performing the second access to the shared memory using the at least one of other 

processors- 

10 According to this invention, the selecting includes selecting one processor and 
permitting the selected processor to access the shared memory, in a case where the 
plurality of processors are in contention for the shared memory. The performing the first 
access to the shared memory includes performing access to the shared memory using the 
processor selected at the selecting. The requesting includes requesting at least one of 

15 other processors included in the plurality of processors, in a case where the first access 
(including updating of predetermined data, for example) has been performed to the shared 
memory. The performing the second access includes performing access (including re- 
reading of the same data from the shared memory, executing the process for updating the 
predetermined data in the shared memory, etc.) to the shared memory using the at least 

20 one of other processors. As a result of this, the predetermined information can be 
transmitted between each of the plurality of processors, and the recovery process for 
recovering the failure in updating the data in the shared memory or a confirmation 
process for confirming whether the data is updated in the shared memory can successfully 
be performed. 

25 In order to achieve the above objects, according to the sixth aspect of the present 
invention, there is provided a computer readable recording medium for controlling a 
computer to execute a shared-memory controlling method comprising: 
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selecting one processor included in a plurality of processors, and permitting the 
selected one processor to access a shared memory, in a case where the plurality of 
processors are in contention for the shared memory; 

performing first access to the shared memory using the selected processor; 
5 requesting at least one of other processors included in the plurality of processors to 
perform second access to the shared memory, in a case where the performing the first 
access to the shared memory has been done; and 

performing the second access to the shared memory using the at least one of other 
processors. 

10 In order to achieve the above objects, according to the seventh aspect of the present 
invention, there is provided a data signal embodied in a carrier wave and representing an 
instruction sequence for controlling a computer to execute a shared-memory controlling 
method comprising: 

selecting one of a plurality of processors, and permitting the selected processor to 
15 access a shared memory shared by the plurality of processors, in a case where the 
plurality of processors are in contention for the shared memory; 

performing firs access to the shared memory using the selected processor, 
requesting at least one of other processors included in the plurality of processors to 
perform second access to the shared memory, in a case where the first access has been 
20 done; and 

performing the second access to the shared memory using the at least one of other 
processors. 

BRIEF DESCRIPTION OF THE DRAWINGS 
These objects and other objects and advantages of the present invention will become 
25 more apparent upon reading of the following detailed description and the accompanying 
drawings in which: 

FIG. 1 is a block diagram exemplarily showing the structure of a multiprocessor 



system according lo an embodiment of the present invention; 

FIG. 2 is a block diagram exemplarily showing the structure of each of a processor, 
a contention determiner and a shared memory which are included in the multiprocessor 
system of FIG. 1; 

5 FIG. 3 is an exemplary diagram for explaining the relationship between software 
programs which are executed in each processor shown in FIG. 2; 

FIGS. 4A and 4B are flowcharts for explaining an accessing process carried out by 
the multiprocessor system of FIG. 1; and 

FIG. 5 is a flowchart for explaining an interruption process carried out by the 
10 multiprocessor system of FIG. 1. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 
A multiprocessor system according to an embodiment of the present invention will 
now be explained with reference to ihe accompanying drawings. 

In the multiprocessor system of the present invention, each of processors efficiently 
15 accesses data, stored in a shared memory in cooperation with each other, and executes a 
predetermined process. 

FIG. 1 is a block diagram exemplarily showing the structure of a system including a 
multiprocessor system 100 according to the embodiment of the present invendon. In 
this system, the multiprocessor system 100 is connected to a server 70 through a LAN 
20 (Local Area Network) 80. The multiprocessor system 100 is connected to a iscording 
medium 90 including a magnetic disk, a semiconductor memory or the like, for example. 

As shown in FIG. 1, the multiprocessor system. 100 comprises a plurality of 
processors 10-1 to 10-n, a contention determiner 50 and a shared memory 60. Each of 
the processors 10-1 to 10-n is connected to the server 70 through the LAN 80, and 
25 appropriately downloads data (service data, etc.) therefrom. 

FIG. 2 is a block diagram exemplarily showing the structure of each of the 
processors 1 0-1 to 10-n and the shared memory 60, etc. 
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As shown in. FIG. 2, each of the processors 10-1 to 10-n comprises a CPU (Central 
Processing Unit) 20, an interruption-request register 21, an interruption-display register 
22, a reset register 23, an REQ register 24, an ACK register 25, a main memory 30, an 
LAN controller 40 and a system bus 41. 
5 The CPU 20 reads out and executes an application software program 33 and an 
exclusive-control software program 34 which are stored in the main memory 30, and 
entirely controls the processor 10. 

The interruption-request register 21 of one of the processors 10-1 to 10-n is 
controlled by the CPU 20 executing the exclusive-coatrol software program 34, and sends 
10 various request information to other processors 1,0-1 to 10-n, Specifically, the 
interruption-request register 21 of one of the processors 10-1 to 10-n sends, to other 
processors 10-1 to 10-n, request information for requesting to rc-rcad service data 62 
stored in the shared memory 60 or request information for requesting to update the 
service data 62. 

15 The interruption-display register 22 of one of the processors 10-1 to 10-n receives 
various request information sent form other processors 10-1 to 10-n (the interruption- 
request register 21 of other processors 10-1 to 10-n). Upon reception of the request 
information from one of the processors 10-1 to 10-n, the interruption-display register 22 
of each of other processors 10-1 to 10-n causes the CPU 20 to begin a corresponding 

20 interruption process. Specifically, in response to the received request information, the 
interruption-display register 22 outputs an instruction signal for activating an interruption 
handler (an interruption handler program 36, as will be explained later) included in the 
exclusive-control software program 34, to the CPU 20. 

The reset register 23 is controlled by the CPU 20 executing the exclusive-control 

25 software program 34, and sends information for requesting to reset other processors 10-1 
to 10-n, to the contention determiner 50. That is, the reset register 23 sends request 
information for requesting to reset other processors 10-1 to 10-n, to the contention 
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determiner 50. 

The REQ register 24 is controlled by the CPU 20 executing the exclusive-control 
software program 34, and sends information for requesting to access the shared memory 
60, to the contention determiner 50. Specifically, the REQ register 24 sends information 
5 "1" (ON information) to the contention determiner 50 when requesting to access the 
shared memory 60, and sends information "0" (OFF information) to the contention 
determiner 50 when accessing of the shared memory 60 is completed. 

The ACK register 25 receives access-permission information sent from the 
contention deteiminer 50, and provides the CPU 20 with the received access-permission 
10 information. Specifically, the ACK register 25 receives the information "1" (ON 
information) representing that it is permitted to access the shared memory 60, from the 
contention dctcrmiiicr 50, and supplies the CPU 20 with the received information. 

In the case where two or more processors 10-1 to 10-n are in contention for the 
shared memory 60, the contention determiner 50 selects one of the contending processors 
15 1 0-1 to 1.0-n, and sends information "1" to the ACK register 25 of the selected processor 
10. 

The main memory 30 includes, for example, a DRAM (Dynamic Random Access 
Memory), and stores service-data management inibrmadon 31, the service data 32, the 
application software program 33 and the exclusive-control software program 34. 
20 The service-data management information 31 is information for managing the 
service data 32, and read out from the shared memory 60. 

The service data 32 is target data to be processed in its processor 10, and read out 
from the shared memory 60. 

The application software program 33 is a program for executing a predetermined 
25 process in its processor 10, and executed by the CPU 20. 

The exclusive-control software program 34 is a program fox executing an exclusive- 
control process in its processor 10, and executed by the CPU 20. 
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The CPU 20 executing the exclusive-control software program 34 performs 
exclusive control for the shared memory 60 in association with other processors 10-1 to 
10-n, in cooperation wilh the RbQ register 24, the ACK register 25 and the contention 
determiner 50. The CPU 20 executing the exclusive-control software program 34 
5 executes a recovery process for recovering the contention determiner 50 in cooperation 
with the interruption-request register 21, the interruption-display register 22 and the reset 
register 23, in the case where the contention determiner 50 is in an abnormal condition. 

In more particular, as shown in FIG. 3, the exclusive-control software program 34 
includes an access-request program 35 and an interraption-handler program 36. 
1 0 The access-request program 35 is a program for receiving a request for accessing the 
shared memory 60 from the application software program 33 and for sending thus 
received request to other processors 10-1 to 10-n. 

The interruption-handler program 36 is a program for receiving a request, etc. sent 
from other processors 10-1 to 10-n and for sending thus received request to the 
15 application software program 33. 

As shown in FIG. 2, the LAN controller 40 controls communications between the 
processor 10 and the server 70 which are connected with each other through the LAN 80. 
The processor 10 downloads the service data, etc. from the server 70 to the shared 
memory 60, etc., using this LAN controller 40. 
20 The system bus 41 connects the LAN controller 40 with the main memory 30, etc. 
within its processor 10, and connects also the main memory 30 with the contention 
determiner 50, etc. hi this structure, the memory 30 can be connected with the shared 
memory 60, and the processor 10 can send and receive service data, etc. through the 
contention determiner 50. 
25 In the case where two or more processors 10-1 to 10-n are in contention for the 
shared memory 60, the contention determiner 50 selects one of the contending processors 
10-1 to 10-n, and permits the selected processor 10 to access the shared memory 60. 
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The shared-memory 60 is a memory shared by the processors 10-1 to 10-n, and 
includes a flash memory, etc. The shared-memory 60 stores the service data 62, which 
is the data each of the processors 10-1 to 10-n downloaded from the server 70, and 
service-data management information 61 , for managing the service data 62. 
5 la the multiprocessor system 100 having the above structure, predetermined 
information is transmitted between the plurality of processors 10-1 to 10-n, thereby a 
recovery process, a confirmation process, etc. can be performed in cooperation with each 
other. 

Operations of the multiprocessor system 100 according to the embodiment of the 
1 0 present invention will now be described with reference to FIGS. 4 A, 4B and 5. 

FIGS. 4A and 4B are flowcharts for explaining an accessing process which is 
carried out by the multiprocessor system 100 in accordance with the access-request 
program 35. FIG. 5 is a flowchart for explaining an interruption process carried out by 
the multiprocessor system 100. 
1 5 The accessing process wi.11 now be explained with reference to FIGS. 4A and 4B. 

As shown in FIG. 4A, if a request for accessing the shared memory 60 is issued in 
the application software program 33, the exclusive-control software program 34 is 
activated (Step S401). fa more particular, the access-request program 35 included in Lhe 
exclusive-control software program 34 is activated. 
20 Upon reception of the request for accessing, the activated access-request program 35 
sets "1" in the REQ register 24 to request for accessing the snared memory 60 (Step 
S402). That is, the REQ register 24 sends information "1" (ON information) to the 
contention determiner 50. 

The contention determiner 50 determines whether two or more of the processors 10- 
25 1 to 10-n are in contention for the shared memory 60, in accordance with the information 
sent form the REQ register 24 of each of the processors 10-1 to 10-n„ and sends 
information to the ACK register 25 of one of the processors 10-1 to 10-n (Step S403). 
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That is, in the case where it is determined that the processors 10-1 to 10-n are in 
contention, for the shared memory 60, lhe contention determiner 50 selects one of the 
processors 10-1 to 10-n, and permits the selected processor 10 to access (he shared 
memory 60 in accordance with predetermined conditions. 
5 On the contrary, in the case where it is determined that the processors 10-1 to 10-n 
arc not in contention for the shared memory 60, the contention determiner 50 permits the 
requesting processor 10 to access the shared memory 60. The contention determiner 50 
sets "1" in the ACK register 25 of the requesting processor 10. 

The access-request program 35 of the exclusive-control software program 34 
1 0 occasionally monitors the value of the ACK register 25 included in its processor 10, and 
detennines whether the value of the ACK register 25 is "1" (Step S404). 

In the case where it is determined that the value of the ACK register 25 is not "1", 
the access-request program. 35 go on to Step 418 of the process shown in FIG. 4B. On 
the contrary, in the case where it is determined that the value of the ACK register 25 is 
15 "1", the access-request program 35 informs the application software program 33 of the 
access permission (Step S405). 

The application software program 33 performs accessing the shared memory 60 
(Step S406). 

The application software program 33 determines whether the process for accessing 
20 the shared memory 60 is a process for writing data thereinto (Step S407). 

In the case where it is determined that the process for accessing the shared memory 
60 is not the process for writing data thereinto, the application software program 33 sets 
the value of the REQ register 24 to "0" when the accessing is completed (Step S408). In 
this case, the accessing toward the shared memory 60 is completed, without modifying me 
25 data stored in the shared memory 60. 

In the above step S407, in the case where it is determined that the accessing toward 
the shared memory 60 is performed for writing data thereinto, the application software 
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program 33 determines whether the accessing process is normally terminated (Step S409). 

In the case where it is determined that the accessing is not normally tenninated (i.e., 
the accessing is terminated abnormally), the application software program 33 go on to 
Step S414 shown in FIG. 4B, as will be explained later. In the case where it is 
5 determined that the accessing is terminated normally, the application software program 33 
sets the value of the REQ register 24 to "0" (Step S410), and requests other processors 
10-1 to 10-n to re-read the updated data (Step S411). That is, the application software 
program 33 sends re-read requesting information to the exclusive-control software 
program 34 included in the same processor 10, to control the main memory 30 of each of 
10 other processors 10t1 to 10-n to write the service data 62 and service-data management 
information 61 updated by the application software program 33. 

The exclusive-control software program 34 sets " 1" in a re-read-rcque sting bit of the 
interruption-request register 21, and sends the re-read request to other processors 10-1 to 
10-n (Step S412). 

1 5 Upon reception of the rc-rcad request, the interrupdon-dispiay register 22 of each of 
other processors 10-1 to 10-n outputs an interrupdon signal for instructing its CPU 20 to 
re-read the updated data (Step S413). 

In the above-described Step S409, in the case where it is determined that the 
accessing is not normally terminated (i.e., terminated abnormally), the flow advances the 

20 process of FIG. 4B, and the application software program 33 sets the value of the REQ 
register 24 to "0" (Step S414). Further, the application software program 33 sends 
update-request information to the exclusive-control software program- 34 included in the 
same processor J O, to control other processors 10-1 to 10-n to update the non-updated 
service data 62 and service-data management information 6 1 for the application software 

25 program 33 that could not update the data (Step S415). 

The exclusive-control software program 34 sets "1" in an update-request bit of the 
interruption-request register 21, and sends an update request for requesting other 
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processors 10-1 to 10-n to update the non-updated data (Step S416). 

Upon reception of the update-request, the intermption-display register 22 of each of 
other processors 10-1 to 10-n outputs, to the CPU 20 included in the same processor 10, 
an interruption signal for instructing the CPU 20 to update the service data 62 and 
5 service-data management information 61 (Step S417). 

In the step 404 shown in FIG. 4A, in the case where it is determined that the value 
of the ACK register 25 is not "1", the access-request program 35 included in the 
exclusive-control software program 34 determines whether a predetermined latency time 
has elapsed (Step S418). 
10 In the case where it is determined that the piedetermined latency time has not 
elapsed, the access-request program 35 returns bade to the above step S404 shown in FIG. 
4A. On the contrary, in the case where it is determined that the predetermined latency 
time has elapsed, the access-request program 35 informs the application software program 
33 that the predetermined latency time has elapsed (Step S419). 
15 The application software program 33 cancels the access toward the shared memory 
60 (Step S420), sets the REQ register 24 to "0" (Step S421), and requests other processors 
10 to reset themselves (Step S422). 

The exclusive-control software 34 sets in the reset-request bit of the 
interruption -request register 21 , and sends other processors 10 a reset request for resettin g 
20 themselves (Step S423). 

Upon reception of the request from the exclusive-control software 34, the 
intermption-display register 22 included in each of other processors 10-1 to 10-n outputs 
an interruption signal, to the CPU 20 included in the same processor 10, for mstracting 
the CPU 20 to reset the processor 10 (Step S424). 
25 An interruption process will now be explained with reference to FIG. 5. 

The CPU 20 receives an interruption signal (Step S501) which has been output at 
any of the steps S413, S417 and S424 of FIGS. 4A and 4B. 
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Upon reception of the interruption signal, the exclusive-control software program 34, 
more particularly the interruption handler program 36 included in the exclusive-control 
software program 34, is activated (Step S502). 

The activated interruption handler program 36 detects bits of a signal (a plurality of 
5 bits) output from the interruption-display register 22, and checks the contents of the 
received interruption signal (Step S503). 

m the case where the contents of the received interruption signal is a request for re- 
reading the service data 62, etc., the interruption-display register 22 clears the interruption 
signal (S504), and sends a re-read request to the application software program 33 (Step 
10 S505). That is, the interruption handler program 36 informs the application software 
program 33 that there is sent a request for re-reading the service data 62, etc. from other 
processors 10-1 to 10-n. 

The application software program 33 reads out the service-data management 
information 61 from the shared memory 60 (Step S506), reads out only the updated 
15 service data 62 based on the read information, and updates the read data in the main 
memory 30 (Step S507). 

In the above-described step S503, in the case where it is determined that the 
contents of the interruption signal represents a request for updating the data, the 
interruption handler program 36 clears the interruption signal (Step S508), and sends an 
20 update request for updating the data to the application software program 33 (Step S509). 
That is, the interruption handler program 36 informs the application software program 33 
that there is sent an update request from other processors 10-1 to 10-n. 

The application software program 33 downloads data from the server 70 for other 
processors 10-1 to 10-n, and updates the service data 62, etc. stored in the shared memory 
25 60 (Step S510). 

In the above-described step S503, in the case where it is determined that the 
contents of the interruption signal represent a request for resetting the processor 10, the 
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interruption handler program 36 clears the interruption signal (Step S511), and sets "1" in 
the reset register 23 (Step S512). 

In the case where "1" is set in the reset register 23, the hardware included in each 
processor 10 resets itself (Step S5 1 3). That is, the contention determiner 50 forces itself 
5 to be reset, and each of the processors 10- 1 to 10-n resets the REQ register 24 and ACK 
register 25, 

As explained, in the multiprocessor system 100 having the above structure, 
predetermined information is transmitted between the plurality of processors 10-1 to 10-n, 
thereby a recovery process for recovering data upon failure of updating data in the shared 
1 0 memory 60 and a confirmation process for confirming whether data is to be updated in 
the shared memory 60, etc. can be performed in cooperation with each other. In the 
structure where each of the processors 10-1 to 10-n includes a reset register for instructing 
to reset the processor 10, each processor can be reset. 

As a result, predetermined information is transmitted between the plurality of 
15 processors, and a recovery process for recovering the failure in updating data in the 
shared memory and a confirmation process for confirming whether data is updated in the 
shared memory can be achieved in cooperation with each other. 

fii the above embodiment, in the accessing process (Steps S404 and S418) shown in 
FIGS. 4A and 4B, the value of the ACK register 25 is frequently monitored, and a 
20 response (access permission) from the contention determiner 50 is checked based on the 
value of the ACK register 25. However, how to check the response from the contention 
determiner 50 is arbitrary. 

For example, when a response is sent from the contention determiner 50, an 
interruption signal is generated, and the value of the ACK register 25 is checked in 
25 accordance with the generated interruption signal, so as to check the response from the 
contention determiner 50. 

In the above embodiment, data is downloaded from the server 70 in the interruption 
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process (Step S510) shown in F1G 7 5, and the service data 62, etc. stored in the shared 
memory 60 is updated. However, in the case of failure in downloading data from the 
server 70, the service data 32, etc. stored in the main memory 30 may be updated back 
into the form of the service data 62 in the shared-memory 60. 
5 For example, in the case where the downloading of the data from the server 70 has 

not been succeeded, it can be assumed that a something undesired event occurs between 
the server 70 and the processor 10. In this case, mere is no use in performing data 
communications with the server 70, and an abnormality of the service data 62 stored in 
the shared memory 60 can. not be recovered. 
10 Hence, in the case where the downloading is not successfully achieved, the 

application software program 33 abandons the downloading from the server 70, and 
updates the service data 32 in the main memory 30 back into the service data 62 of the 
shared memory 60. In this structure, after the server 70 is activated again next time, a 
normal process of do wnloading data from the server 70 can be achieved. 
15 In the above embodiment, in the interruption process (Step S513) shown in FIG, 5, 

the processor 10 resets the REQ register 24 and the ACK register 25. At the same time, 
a process for resetting the software inside each processor 10 can be executed. This is 
because the software inside each processor 10 may be reset as a result of being out of 
control, hi this case, the software inside each processor 10 is reset, and then the REQ 
20 register 24 and ACK register 25 are reset afterwards. 

The multiprocessor system 100 according to the above embodiment is not limited to 
a system for downloading data from the server 70, etc. The multiprocessor system 100 
can be employed for a system (an Embedded System) which is embedded in various units, 
etc. 

25 The multiprocessor system according to the embodiment of the present invention 
can realize a function for selecting one processor 10 that is permitted to access the shared 
memory in contention with other processors 10-1 to 10-n and any other functions, in their 
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hardware- like form. A program and data for controlling a computer to execute the 
above-described processes may be recorded on a medium (a floppy disk, CD-ROM, DVD 
or the like) and distributed, and the program may be installed into the computer and run 
on an OS (Operating System) to execute the above-described processes, thereby 
5 achieving the system of the present invention in its software-like form. The above 
program and data may be stored in a disk device or the like in the server device on the 
Internet, and embedded in a earner wave. The program and data embedded in the carrier 
wave may be downloaded into the computer so as to realize the system of the present 
invention. 

10 The exclusive-control software program 34, the access-request program 35, the 
handler program 36 and any other functions which are recorded in the main memory 30 of 
each of the processors 10-1 to 10-n may be realized in their hardware-like form. 

Various embodiments and changes may be made thereonto without departing from 
the broad spirit and scope of the invention. The above-described embodiment is 

15 intended to illustrate the present invention, not to limit the scope of the present invention. 
The scope of the present invention is shown by the attached claims rather than the 
embodiment. Various modifications made within the meaning of an equivalent of the 
claims of the invention and within the claims are to be regarded to be in the scope of the 
present invention. 

20 This application is based on Japanese Patent Application No. 2001-043855 filed on 
February 20, 2001, and including specification, claims, drawings and surnmary. The 
disclosure of the above Japanese Patent Application is incorporated herein by reference in 
its entirety. 



